Digital Circuit Design

Course Code: BBU5202 Electronic Engineering Department

|  |  |
| --- | --- |
| Lab Sheet 3: Introduction to Design using VHDL | Date: **\_\_2015/6/8\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_** |
| Student’s Surname, First Name (in English):  **\_\_\_\_Liu Lele\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_** | Student’s BUPT Number, Class Number: **\_2013213067,\_130800488\_\_\_\_\_\_\_\_\_\_** |
| Email Username (*ee11bxxx*):  **\_\_\_\_liulele@bupt.edu.cn\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_** | Total Mark (out of **50**):  **\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_** |

1. **Learning Objectives**

The aims of this Lab Session is to learn how to use VHDL and ModelSim to design and simulate some basic logic circuits, namely: a NAND gate.

1. **VHDL Experiment steps**

The first stage in the design of my circuit is to create one of the most basic components; this is the NAND gate.

**2.1.1. Creating a Project**

>> Open the Xilinx Project Navigator tool.

>> Create a directory where I save my project.

>> (Xilinx Project Navigator) Select the option **File → New Project…**

>> After filling in the appropriate fields, click the **Next >** button.

>>Choose the settings **Spanrtan2**.

>>Click the **Next >** button.

I now have a project that will contain all your designs, test benches and results. In addition, I can see a window entitled “New Project”, containing an empty table with the fields: **Source File** and **Type**.

The first step in creating a VHDL design is to create the Entity and Architecture pair. In order to do this, I add a new source to my project.

>> Click the **New Source…** button. A window, named “New Source” should appear.

>> Give an appropriate name to the entity, under the tab **File Name**.

>> Ensure I have selected these options in the same window: **VHDL Module** and **Add to project**.

>>Click the **Next >** button in this window and the following one. I can now see a window with a summary of my source.

>> Click the **Finish** button and I can see a window entitled “New Project”.

>> Click the **Next >** button in this window and the following one. This results gives a summary of the project created. Once the project is created, I can proceed to add a new source to your project.

>> Click the **Finish** button.

I can now see a window displaying on the right hand side of my main ISE Project Navigator window, after clicking on the button labelled ***sourceName*.vhd**.

**2.1.2. Creating the Entity**

The Entity declaration describes the device’s interface. This means describing the ‘ports’ and their directions. The NAND gate I will design can be described as below (see **Figure 1**). **Note**: Assume that each input and output is *1-bit* long.

![](data:image/png;base64,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)![](data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAAAAAAAD/2wBDAAMCAgMCAgMDAwMEAwMEBQgFBQQEBQoHBwYIDAoMDAsKCwsNDhIQDQ4RDgsLEBYQERMUFRUVDA8XGBYUGBIUFRT/2wBDAQMEBAUEBQkFBQkUDQsNFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBT/wAARCAABAO0DASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD8qqKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooA//Z)

**Figure 1** – NAND Gate and Entity: representation.

The VHDL code that describes the entity indicated in **Figure 1**, is as below. Copy the code to the VHDL tool window and save the file.

Entity NAND1 is

Port (X, Y: in std\_logic;

Z: out std\_logic);

End NAND1;

**2.1.3. Creating the Architecture**

Next, I need to describe our architecture. The architecture describes the entity’s functionality. Copy the code to my VHDL tool window and save the file.

Architecture Behavioral of NAND1 is

begin

Z <= X nand Y;

end Behavioral;

**2.1.4. Creating the Test Bench**

To run the simulation of my design, I use the ModelSim simulator which requires two kinds of inputs: the circuit description VHDL source file, and a set of stimulus values that define all inputs’ logic and duration.

My steps:

>> Select the ***sourceName*.vhd** tag in the “Project” window.

>> Select the **Project→New Source…** option.

>>Select the **Test Bench Waveform** option. >>Name the file as “*sourceName\_*tbw”.

>>Click the **Next >** button. Ensure that the next window has my chosen “*sourceName*” selected as the associated source.

>>Click the **Next >** button again.

A new window called “New Source Information” appear, containing the test bench specification for the source we chose.

>>Click the **Finish** button.

The HDL Bencher is launched and will be ready for the timing parameters to be entered

>> Change the “Clock Information” to use the option **Combinatorial (or internal clock)**.

>> Click the **OK** button.

>>manipulate the input waveforms.

>> Save the testbench (**File→Save (the waveform)**) and shut it down.

**2.1.5. Generating the Simulation Output Values**

>> In the “Sources in Project” window, select the ***sourceName*\_tbw (*sourceName*\_tbw.tbw)** option.

>> In the “Processes for Source: *sourceName*\_tbw” window, I see the ModelSim Simulator listed as a process. Double-click the **Simulate Behavioral Model** option (on the lefthand side).

The ModelSim simulator opened and run my simulation to the end of the test bench.

>> Exit the ModelSim tool.

1. **Experiment Conclusion**

To achieve a circuit in VHDL, we need to create an object, create an entity, create the architecture, and create the test bench and the simulation output values.